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@ Method and apparatus for operating polyphase DC motors using a PWM chopping signal in zero 
crossing determination. 



@ A circuit for operating a polyphase dc motor has a plurality of driving coils has a circuit that provides 
instantaneous drive currents to selected ones of the driving coils in a each of a plurality of 
predetermined commutation sequences. Circuitry for detecting zero crossings of a back emf voltage of 
the coils is connected into a floating state during each of the predetermined commutation sequences to 
produce a back emf detection signal for timing changes among the predetermined commutation 
sequences. Circuitry controls the drive currents to the selected driving coils to be turned on and off, and 
circuitry delays the zero crossing detection for a predetermined time after the drive currents are 
turned-off. In a preferred embodiment, the circuitry for controlling the drive currents to the selected 
driving coils to be turned on and off comprises circuitry for generating a chop signal when the current in 
the active coils exceeds a predetermined threshold, and more particularly comprises PWM circuitry. 

A method for operating a polyphase dc motor having a plurality of driving coils is presented. 
According to the method, drive current supplied to the driving coils is chopped to control the maximum 
current delivered thereto by turning the drive current on and off. Zero crossings of a back emf voltage of 
the driving coils that are connected into a floating state are detected for producing a commutation 
signal, and the detection of zero crossings is inhibited for a predetermined time after the drive current is 
turned off during the chopping step to avoid detecting a false zero crossing. The chopping is performed 
as a part of a PWM operation. 
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This invention relates to improvements in methods and circuitry for driving polyphase dc motors, and, more 
particularly, to improvements in methods and circuitry for driving polyphase dc motors that employ pulse width 
modulation (PWM) chopping, and still more particularly to improved methods and circuitry for driving poly- 
phase dc motors that provide or enable reliable zero crossing determination for commutation in the presence 

5 of a PWM chopping signal. 

Although the present invention pertains to polyphase dc motors, in general, it finds particular application 
in conjunction with three phase dc motors, particularly of the brushless, sensorless type which are used tor 
rotating data media, such as found in computer related applications, including hard disk drives, CD ROM drives, 
floppy disks, and the like. In computer applications, three phase brushless, sensorless dc motors are becom- 

10 ing more popular, due to their reliability, low weight, and accuracy. 

Motors of this type can typically be thought of as having a stator with three coils connected in a "Y" con- 
figuration, although actually, a larger number of stator coils are usually employed with multiple motor poles. 
Typically, in such applications, eight pole motors are used having twelve stator windings and four N-S magnetic 
sets on the rotor, resulting in four electrical cycles per revolution of the rotor. The stator coils, however, can 

15 be analyzed in terms of three "Y" connected coils, connected in three sets of four coils, each physically sepa- 
rated by 90°. 

In operation, the coils are energized in sequences. In each sequence, a current path is established through 
two coils of the *Y", with the third coil left floating. The sequences are arranged so that as the current paths 
are changed, or commutated, one of the coils of the current path is switched to float, and the previously floating 
20 coil is switched into the current path. Moreover, the sequence is defined such that when the floating coil is 
switched into the current path, current will flow in the same direction in the coil which was included in the 
prior current path. In this manner, six commutation sequences are defined for each electrical cycle in a three 
phase motor. 

In the past, during the operation of a such polyphase dc motor, it has been recognized that maintaining a 
25 known position of the rotor is an important concern. There have been various ways by which this was imple- 
mented. The most widely used way, for example, was to start the motor in a known position, then develop in- 
formation related to the instantaneous or current position of the rotor. One source of such instantaneous pos- 
ition information was developed as a part of the commutation process, and involved identifying the floating 
coil, and monitoring its back emf, that is, the emf induced into the coil as it moves through the magnetic field 
30 provided by the stator. 

When the voltage of the floating coil crossed a particular reference voltage, often zero, the position of 
the rotor was assumed to be known. (Herein, the crossing of the zero voltage, or the reference voltage, is re- 
ferred to as "a zero crossing".) When a zero crossing occurred, the rotor coil commutation sequence was in- 
cremented to the next phase, and the process repeated. 
35 in addition, frequently polyphase dc motors employ pulse width modulation (PWM) to modulate the drive 
current to the coils of the motor. PWM techniques are often used to reduce the power dissipation in polyphase 
motors by chopping the current in the coils of the motor at their peak current levels, to achieve maximum tor- 
que, to allow rapid accelerations, and to reduce the power dissipated in the chip to a level proportional to the 
duty cycle. 

40 Typically when the motor is operating, one or more of the coils is floating (or at high impedance) in each 
commutation state, with the remaining coils being actively driven to produce the desired rotation of the rotor 
of the motor. When, however, the PWM mode is entered, the drive current is temporarily interrupted and al- 
lowed to decay at a predesigned rate. Generally an RC discharge network is provided to determine the decay 
of the current within the drive coils. When the voltage across the resistor sensing the total current through 

45 the motors has decayed to a predetermined level, the drive current is then reapplied to the active coils of the 
motor. This is known in the art as "PWM chopping". 

The PWM chopping of the active coils generates noise inductively coupled to the floating coil or coils of 
the motor. It will be recalled that the back emf of the floating coils is monitored to determine the zero voltage 
crossing for the purpose of sensorless position detection of the rotor of the motor. However, due to the indue- 

so tively coupled noise from the back emf chopping signal into the floating coil, the actual or true zero crossing 
may be difficult to properly detect, since the voltage levels may actually appear higher or lower than the levels 
which would normally appear in the absence of the PWM chopping signal. Thus, in the presence of PWM chop- 
ping, what is needed is a method and circuit for minimizing the effect of the PWM chopping signal to enable 
the zero crossings to be accurately detected for accurate rotor position determination. 

55 in light of the above, it is, therefore, an object of the invention to provide an improved driving method and - 
circuitry for operating a polyphase dc motor. 

It is another object of the invention to provide a driving method and circuit of the type described in which 
pulse width modulation (PWM) chopping is employed. 
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It is another object of the invention to provide an improved driving method and circuit of the type described 
that is less affected by noise spikes produced by a PWM signal than prior circuits. 

It is still another object of the invention to provide an improved driving method and circuit of the type de- 
scribed in which the PWM chopping signal is itself used to sample the output of the back EMF amplifier. 
5 It is another object of the invention to provide a circuit of the type described that minimizes the effects of 

noise induced on account of pulse width modulation chopping of active drive coils into a floating coil on which 
back emf is detected for the purpose of determining the sensorless detection of the position of the rotor of 
the motor. 

It is another object of the invention to provide a method for minimizing the effect of PWM chopping noise 
10 in the detection of the zero crossing of the back emf of a floating coil of a polyphase dc motor. 

These and other objects, features and advantages of the invention will be apparent to those skilled in the 
art from the following detailed description of the invention, when read in conjunction with the accompanying 
drawings and appended claims. 

According to an illustrative embodiment of the invention, in order to sense the voltage on the floating coil, 
15 the PWM chopping signal is used to sample the voltage at an appropriate time when noise spikes have di- 
minished. In this process, the true polarity crossing, that is, the zero crossing, is synchronized to the chopping 
signal. Although this may inherently introduces an error in the exact time measurement of the zero crossing 
occurrence, if the chopping frequency is relatively high, then the error introduced by the chopping period is 
small enough to still allow reliable commutation. Therefore, in accordance with the invention, when the motor 
20 driver is put in the PWM mode, the PWM chopping signal is used in an edge-triggered fashion to sample the 
output of the back EMF amplifier with a D-type flip-flop. 

In accordance with a broad aspect of the invention, a circuit for operating a polyphase dc motor has a plur- 
ality of driving coils. A circuit provides instantaneous drive currents to selected ones of the driving coils in a 
each of a plurality of predetermined commutation sequences. Circuitry for detecting zero crossings of a back 
25 emf voltage of the coi Is is connected into a floating state during each of the predetermined commutation se- 
quences to produce a back emf detection signal for timing changes among the predetermined commutation 
sequences. Circuitry controls the drive currents to the selected driving coils to be turned on and off, and cir- 
cuitry delays the zero crossing detection for a predetermined time after the drive currents are turned-off. In 
a preferred embodiment, the circuitry for controlling the drive currents to the selected driving coils to be turned 
30 on and off comprises circuitry for generating a chop signal when the current in the active coils exceeds a pre- 
determined threshold, and more particularly comprises PWM circuitry. 

In accordance with another broad aspect of the invention, a method for operating a polyphase dc motor 
having a plurality of driving coils is presented. According to the method, drive current supplied to the driving 
coils is chopped to control the maximum current delivered thereto by turning the drive current on and off. Zero 
35 crossings of a back emf voltage of the driving coils that are connected into a floating state are detected for 
producing a commutation signal, and the detection of zero crossings is inhibited for a predetermined time after 
the drive current is turned off during the chopping step to avoid detecting a false zero crossing. The chopping 
is performed as a part of a PWM operation. 

The invention is illustrated in the accompanying drawings, in which: 
40 Figure 1 is an electrical schematic block diagram of a motor driver system incorporating apparatus in ac- 
cordance with a preferred embodiment of the invention. 

Figure 2 is an electrical schematic diagram of the power stage used in the motor driver system of Figure 
1 for providing motor driving signals to the "Y" connected stator coils of the motor with which the driver system 
might be associated. 

45 Figure 3 is an electrical schematic diagram of a typical "Y" connected rotor coil arrangement, illustrating 
the current flow direction for 6 phases of a 3 phase motor. 

Figure 4 is an electrical schematic diagram of a sequencer circuit and PWM switching network used in 
the motor driver system of Figure 1 . 

Figure 5 is an electrical schematic diagram a back emf amplifier and zero crossing detector used in the 
so motor driver system of Figure 1 together with circuitry to select a desired sampling time for zero crossing de- 
tection. 

Figure 5a shows various voltage waveforms generated at the output of the zero crossing detector of Figure 
5, illustrating their timed relationship to a detected rising or falling zero crossing. 

Figure 6 is an electrical schematic diagram of a zero crossing logic switching circuit used to control the 
55 back emf amplifier connections in the circuit of Figure 5. 

Figure 7 is an electrical schematic diagram of a circuit for generating a sequencer noise mask and a coil 
switching transient noise mask, for use in the motor driver system of Figure 1. 

And Figure 8 are electrical waveforms showing the voltage signals at various points in the circuit of Figure 
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1 with respect to several electrical cycles of the motor with which the driver circuit may be associated. 

In the various figures of the drawing, like reference numerals denote like or similar parts. 

A portion of an electrical schematic block diagram of a motor controller 10 in which the apparatus and 
method in accordance with a preferred embodiment of the invention may be incorporated is shown in Figure 
5 1. Although the motor controller can be constructed of discrete components, preferably, the motor controller 
10 is integrated onto a single semiconductor chip adapted for connection to the stator coils of a three phase 
dc brushless spindle motor, for use, for example, to turn a magnetic or other disk in systems such as computer 
hard disk drives, cd-rom drives, floppy disk drives, and the like. Such 3 phase motor preferably has Y connected 
stator windings, although such Y configured winding connections are not essentially required. 
w The windings can be connected to output terminals OUT A, OUT B, OUT C and CTR TAP, as below de- 
scribed in further detail. It should be noted that although a preferred embodiment of the invention is described 
with regard to a three phase motor, in particular, the principles of the invention can be equally advantageously 
applied to polyphase motors, in general. 

The driving voltage is provided to the output terminals OUT A, OUT B, and OUT C by a power stage 11, 
15 which may be configured as described below with reference to Figure 2. The power stage 1 1 is sequenced to 
provide sequential control output signals to the output terminals OUT A, OUT B, and OUT C by a sequencer 
circuit 13, described below with reference to Figure 4, and a signal interface circuit 12 supplies the output sig- 
nals from the sequencer circuit 13 to the power stage 11, as well as enabling other functions, such as brake 
and output enable functions. The sequencer 13 also provides drive and sequence signals on an "internal com- 
20 mutation bus" 66 to other circuits of the controller circuitry to control the various aspects of rotation of the 
motor driven by the circuit 10. 

The output terminals OUT A, OUT B, and OUT C are also switchably connected to a back-emf sense am- 
plifier 14, the details of which are described with reference to Figure 5 below. The back-emf sense amplifier 
14 in turn delivers signals to a zero crossing detector circuit 16, illustrated in Figure 5 below, which provides 
25 input signals to a digital delay circuit 17, described in detail in Figure 7 below. The output of the digital delay 
circuit 17 controls the operation of the sequencer 13, in a manner below described in detail. 

The motor controller circuitry also includes pulse width modulation circuitry 18, the operation of which be- 
ing described in greater detail with respect to Figures 4 and 5 below. 

Additionally, the motor controller circuitry 1 0 includes system clock circuitry 23, and phase lock loop (PLL) 
30 frequency/phase detector circuitry 24, and may include various other circuitry, not shown, such as circuitry 
to support "align and go" start up circuitry to facilitate start up of the motor from a stopped condition, port con- 
trol logic and associated shift register circuitry to facilitate control of the motor controller circuitry by an ex- 
ternal microprocessor (not shown), and so forth. 

Referring now to Figure 2, the power stage 11 of the motor control circuitry 10 is a conventional H-bridge 
35 30, commonly referred to as a triple - Vz - H - bridge, connected to switchably deliver driving currents to the 
"Y" connected stator windings 32, 33, and 34. The bridge 30 has three series current paths 37, 38, and 39 
between a supply voltage applied to a line 40, and a reference potential on line 42. Each current path includes, 
respectively, two switching transistors 44 and 45, 44' and 45', and 44" and 45". The transistors 44, 44', 44", 
45, 45* and 45" can be of known power switch FETs, or other switch devices, as desired. The line 42 is con- 
40 nected to an external sense resistor 49 (externally connected to terminals R SENSE, as shown in Figure 1), 
which in turn is connected to ground. 

One end of each of the stator coils 32, 33, and 34 is connected together at a common center tap 36, the 
other ends being connected to respective nodes OUT A, OUT B, and OUT C between the respective pairs of 
switching transistors 44 - 45; 44' - 45', and 44" - 45". Each of the switching transistors 44, 45, 44/ 45', 44", 
45 and 45" has a flyback diode 47, 48; 47', 48'; and 47", 48" in parallel with its current path, as shown. 

In operation, during an energized phase, one node (for example, node OUT A) is driven high by one of the 
upper switches 44. Another node (for example, node OUT B) is driven low by one of the lower switches 45', 
and the other node (for example, node OUT C) is left floating with both switches 44" and 45" off. This is com- 
monly to as the "AB phase". 

so The coils are then switched in a commutation sequence determined by the sequencer circuit 13 in a man- 
ner such that in each commutation phase, current always flows in two of the three coils, with the third coil 
floating, and that after switching current will continue to flow, and in the same direction, in one of the two 
coils in which current was flowing in the previous phase. More particularly, as shown in the diagram of Figure 
3, in a three phase motor, actually six operational phases exist. The current flows in each of these six phases 

55 as shown in the following Table A: 
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TABLE A 



5 



10 



Phase 


Current Flows From: 


To: 


Floating Coil: 


1 


A 


B 


C 


2 


A 


C 


B 


3 


B 


C 


A 


4 


B 


A 


C 


5 


C 


A 


B 


6 


C 


B 


A 



The switching of the driver transistors of the power stage 11 to effect the switching currents for each phase 
is accomplished by a sequencer circuit 13 and an associated interface circuit 12, details of which being shown 
in Figure 4. The sequencer circuit 13 provides signals through the interface circuit 12 to the upper driver outputs 
52 and the lower driver outputs 53 to accomplish the switching sequence outlined above in Table A. The upper 
and lower driver outputs 52 and 53 are connected through the PWM switching network (one of which 56 being 
shown for the upper and lower "A" drivers) to the upper and lower driver input lines, shown in Figure 2. The 
construction and operation of the PWM switching network 56 is described in detail in copending patent appli- 
cation serial number 728,597, filed July 11, 1992, assigned to the assignee hereof, and incorporated herein 
by reference. 

The sequencer circuit 1 3, more specifically, includes a shift register 55 that determines the specific upper 
and lower output lines which are activated at any particular instant To accomplish the proper switching se- 
quence, an appropriate sequence may be initially loaded into the shift register 55, and sequentially shifted 
through the various data positions of the shift register 55. For example, one data sequence in the embodiment 
shown which will produce the commutation sequence of Table A as it is clocked through the shift register 55 
to sequentially appear at the outputs Q, - Qe might be "110000". 

The shift register 55 is clocked by an increment signal introduced into the shift register 55 from a delay 
counter 112, described in detail below with respect to Figure 7. Thus, the shift register 55 operates at any in- 
stant to present a high state on a selected two adjacent ones of the outputs Qj - Qe to turn on the corresponding 
upper and lower transistors according to the sequence shown in Table A, with the remaining outputs turned 
off. 

The other circuitry of the sequence circuit 13 includes a reset line 59 to initialize or reset the shift register 
55, reestablishing the commutation sequence code above described in an initial starting position within the 
shift register 55. The outputs Q t - Q 6 of the shift register 55 are also connected via lines of an internal com- 
mutation bus 66 to the zero voltage crossing logic control circuit of Figure 6, described below. 

By virtue of the direct connection to the output lines of the shift register 55 of the sequence generator 13, 
the drivers of the power stage 11 can be tristated by appropriate signals applied to the signal interface circuit 
12, without loss of the desired commutation signals. That is, if the commutation signals were to be derived for 
internal circuit use in detecting zero crossings, for example, at the output of the signal interface circuit, if the 
motor drivers were to be tristated, the commutation signals would be lost, and there would be no hope of re- 
establishing synchronization between the commutation signals and the motor without slowing the motor or 
employing complex resynchronization algorithms. 

If desired, a brake signal developed elsewhere, perhaps externally to the motor control circuit 10, may be 
applied on line 67 to logic circuit 63 to prevent output to the motor on the upper and lower driver output lines 
52 and 53 when such brake signal exists. The brake signal, which may be a software generated or external 
signal, is applied in the embodiment illustrated to turn on all the lower drivers, and to turn off ail of the upper 
drivers. At the same time all of the coils 32, 33, and 34 may be shorted together so that the eddy currents 
generated by the magnetic field in the coils 32, 33, and 34 brakes the motor. 

Also, signals which might be generated in response to an internal error or other abnormal condition, or to 
an external enable signal that would not require the motor to be braked, but which may require the removal of 
drive signals to the coils of the motor, may be applied on a line 68 to the final driver logic gates 63 as shown. 
Thus, in the presence of a signal on the line 68 (that is, a change to a low state from a normally high state), 
the drive is removed or inhibited from both the upper drivers 52 and the lower drivers 53 allowing the rotor of 
the motor to coast 

The commutation among the coils 32, 33, and 34 is performed in response to information indicating the 
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specific unambiguous position of the rotor of the motor in conjunction with circuit information indicating the 
desired position of the rotor. More specifically, the commutation to apply the each successive sequence of 
Table A is determined in response to a corresponding coil reaching a particular rotational position and its cor- 
relation with sequencer information indicating where the motor should be at a particular time prior to when a 

5 commutation is to occur. The determination of the precise rotational location of the rotor is continuously being 
updated by monitoring the zero crossing voltage in each non-driven, or floating, coil. More particularly, as the 
coils 32, 33, and 34 are switched during the commutation sequence of the rotor, the voltage of the floating 
coil is monitored by the back emf amplifier circuit 14 shown in Figure 5. 

The back emf amplifier circuit 14 includes switches 81, 82, and 83 respectively connected to the motor 

10 driver outputs OUT A, OUT B, and OUT C, in the circuit of Figure 2 to connect a selected one of the coils con- 
nected to the outputs OUT A, OUT B, or OUT C to the non-inverting input of a comparator 85. The particular 
one of the coils 32, 33, or 34 which is connected to the comparator 85 corresponds to whichever of the coils 
is expected to be floating (not necessarily the coil which is actually floating). Although the term "floating" is 
used herein to indicate the coil which is not in the instantaneous current path, the coils do not actually "float", 

16 but are connected to a tristate impedance when no drive current is being applied. The switches 81, 23, and 
83 are operated by the circuit of Figure 6, below described, to effect the switching of the coil expected to be 
floating, as just described. 

The center tap connection 36 (see Figure 2) of the rotor is connected to the inverting input of the com- 
parator 85, so that when the voltage on the selected floating coil becomes larger than the center tap voltage, 

20 the comparator produces an output, representing the zero voltage crossing of the voltage on the selected float- 
ing coil. (The voltage which is applied to the input to the comparator 85 is the so-called "back emf" of the coil, 
the voltage generated in the selected floating coil as it moves through the magnetic field within the motor.) 
The comparator 85 is designed to have some hysteresis, because otherwise the occurrence of a voltage be- 
yond the zero crossing voltage may not last a sufficiently long time to enable the output signal of the compar- 

25 ator 85 to be useful. 

With further reference to Figure 5, the output from the comparator 85 is connected to a shift register 88 
through a transmission gate 89. A mask signal generated in the sequencer circuit 13 (described below with 
respect to Figure 4) is applied on a line 120 to an enable input of the transmission gate 89 so that the output 
from the comparator 85 is inhibited from being applied to the shift register 88 during the mask period following 
30 a phase commutation by the sequencer circuit 1 3. When, however, the output signal from the comparator 85 
is enabled to pass the signal applied to the transmission gate 89, the signal is applied to the D input of the 
first D-type flip flop 202 in the flip flop series, including D-type flip flops 90, 91, 92, and 93 forming the shift 
register 88. 

The circuitry 80 for sampling a signal from the back emf amplifier 85 to detect zero crossings of the coil 

35 that is instantaneously floating, as switchably connected to the back emf amplifier 85 by one of switches 81- 
83, includes a pulse width modulation detection circuitry 200 for enabling the sampling circuitry in the presence 
of pulse width modulation operation of the motor. The circuitry 200 includes a D-type flip-flop 202. The D input 
of the flip-flop 202 receives the output from the transmission gate 89 that represents the output of the back 
emf amplifier 85 when enabled by the absence of a mask on line 120. The Q output of the flip-flop 202 is con- 

40 nected to the D-type flip-flop 90. The flip-flop 202 is clocked by signals by the gating network that includes 
three NAND gates 205, 206, and 207. 

The control inputs to the gates 205-207 are the PWM ON signal on node 21 0 and the PWM chopping signal 
on node 211. The PWM ON signal on node 210 is derived from circuitry 215 (see Figure 2). The PWM ON 
signal is generated when the voltage on the sense resistor 49 exceeds a predetermined threshold value indi- 

45 eating that a higher than desired current exists in the coils 32-34 of the motor. Typically, such over-current 
conditions exist during startup of the motor, although other conditions may exist that result in the current 
threshold being exceeded. 

The other input to the network of NAND gates 205-207 is a signal entitled "ZCPWM" on node 211. The 
"ZCPWM" signal is derived from the two-phase non-overlapping clock circuit 214 (see Figure 4). The "ZCPWM" 

so signal is obtained from the clock signal on line 216, inverted by an inverter 217. Thus, with reference again to 
Figure 5, the D-type flip-flop 202 is of the type that is clocked by the falling edge of the clock signal applied 
thereto. As will become apparent, this enables sampling of the state of the output from the back emf amplifier 
85 immediately prior to the activation of the selected upper driver transistors that are simultaneously turned 
on due to the signal on line 216from the two-phase non-overlapping clock215. It will be appreciated thatthe 

55 propagation delay introduced by the flip-flop 202 is much less than the delay that is required for the driver 
transistors to be turned on once a signal is applied to its respective gate. Thus, a relatively "quiet" or stable 
time exists during which the sampling of the floating coil can be accurately observed. 

The network of NAND gates 205-207 is connected with the pulse width modulation ON signal on node 
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210 applied to one input of the NAND gate 206 and to an inverter 220 to produce an output that is connected 
to one input of the NAND gate 205. Thus, depending upon the state of the PWM signal on node 210, one or 
the other of NAND gates 205 and 206 is enabled. The "ZCPWM" signal on the node 211 is connected to the 
other input of the NAND gate 206. Similarly, the high frequency dock that is connected to the clock inputs of 
5 D-type flip-flop circuits 90-93 is connected to the other input of the NAND gate 205. The outputs of the NAND 
gates 205 and 206 are connected to respective inputs of NAND gate 207, the output of which is connected to 
the clock input of the D-type flip-flop 202. 

Thus, in operation, when the circuit 30 is operated in normal mode, the PWM ON signal on node 210 is 
low, thereby enabling the higher frequency clock on line 225 to pass the network of gates 205-207 to clock 
10 the D-type flip-flop 202 to sample the output from back emf amplifier 85. On the other hand, when the circuit 
is operated in PWM mode, the state of the PWM signal on node 210 is high, thereby enabling the "ZCPWM" 
signal on node 211 to clock the D-type flip-flop 202. 

It will be appreciated that the frequency of the "ZCPWM" circuit will be approximately 50 KHz, and, may 
introduce some delay due to the period before the D-type flip-flop 202 is clocked to observe the output of the 
15 back emf amplifier 85 to enable the detection of a zero crossing. However, it should be noted that in a typical 
circumstance in which a pulse width modulation mode is entered, the motor is not necessarily at speed, and 
the fine tuning of the precision for optimum performance is not necessary. 

In operation, therefore, when the circuit is operating in PWM mode, the "ZCPWM" signal clocks the D- 
type flip-flop 202 to enable the back emf amplifier 85 output to be sampled only during a quiescent time im- 
20 mediately prior to a commutation of a respective set of driver transistors 44, 44', or 44". Thus, any noise that 
is induced in the floating coil due to the PWM chopping of the active coils is minimized, and false zero crossings 
are unlikely to be detected. 

The various outputs of the flip flops 90, 91 , 92, and 93 of the shift register 88 are connected to the output 
logic circuit 95, which includes NAND gates 96, 97, 98, and 99. Each of the flip flops 90, 91 , 92, and 93 receive 
25 a clock input, for example from the system clock, and each produces an inverted Q(bar) and non-inverted Q 
output. The Q outputs of flip flops 90, 91, and 92 are applied to the D input of the respective next stage flip 
flops, and the Q output of the last stage flip flop 93 is connected to NAND gate 98 of the output logic circuit 
95. 

The Q outputs of the flip flops 90 and 92 are connected to inputs of the upper NAND gates 96 and 97, 

30 respectively, and the Q outputs of the flip flops 91 and 93 are connected to the inputs of the lower NAND gates 
99 and 98, respectively. On the other hand, the Q(bar) outputs of flip flops 90 and 92 are connected to inputs 
of the lower NAND gates 99 and 98, respectively, and the Q(bar) outputs of flip flops 91 and 93 are connected 
to inputs of the upper NAND gates 96 and 97, respectively. Also, expected slope line 100 corresponding to 
an expected negative-to-positive going zero crossing slope is connected to inputs of NAND gates 96 and 97, 

35 and expected slope line 101 corresponding to an expected positive-to-negative going zero crossing slope is 
connected to inputs of NAND gates 98 and 99. The signals on lines 100 and 101 which indicate the direction 
of the expected zero crossing is generated from the phase information developed in the circuit of Figure 6, 
which in turn, is derived from the outputs of the shift register 55 in the sequencer circuit of Figure 4. 

Finally, the outputs from the logic circuit 95 are connected to the output NAND gates 102 and 103, the 

40 outputs of which being produced in response to the detection of an actual zero crossing of a specified floating 
coil, the zero crossing having a transition in a specified, expected direction, ie, either a negative-to-positive 
going zero crossing transition or a positive-to-negative going zero crossing transition. 

The connections to the output NAND gates 1 02 and 103 are established with the output of the upper NAND 
gate 96 and the lower NAND gate 99 connected to the inputs of the output NAND gate 1 03, and the output of 

45 the upper NAND gate 97 and the output of the lower NAND gate 98 connected to the inputs of the output NAND 
gate 1 02. The line 1 01 on which a signal would appear if a positive slope zero crossing is expected is connected 
to the inputs of the upper NAND gates 96 and 97, and the line 1 00 on which a signal would appear if a negative 
slope zero crossing is expected is connected to the inputs of the lower NAND gates 98 and 99. Thus, the upper 
NAND gates 96 and 97 are responsive the actual occurrence of an expected positive slope zero crossing and 

50 the lower NAND gates 98 and 99 are responsive to the actual occurrence of an expected negative slope zero 
crossing. 

Because of the staged connections at the four stage shift register 88 for each of the positive and negative 
detection paths, the outputs from the output NAND gates 102 and 103 are two pulses, spaced in time, as 
shown in Figure 5a by the curves 109 and 108, respectively, resulting from either a positive-to-negative zero 
55 crossing 106 or a negative-to-positive zero crossing 107. Thus, the pulse generated at the output of NAND 
gate 103 precedes the pulse generated at the output of NAND gate 102 by one clock cycle. The output of the 
NAND gate 103 is used to provide a "load" signal to the counters which measure the required mask and delay 
time after a phase commutation and the output of the NAND gate 102 is used to provide a "reset* signal to 
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the period counter, as below described. 

The circuit for developing the switching signals for the switches 81, 82, and 83, as well as the negative 
and positive slope indicating signals on lines 1 00 and 101 is shown in Figure 6, to which reference is now made. 
The circuit of Figure 6 derives internal phase data on the lines of the internal commutation bus 66 from the 

5 output from the shift register 55 in Figure 4. The lines 66 contain information respectively, from left to right 
indicating signals to upper and lower A, upper and lower B, and upper and lower C drive transistors (see Figure 
2). Thus, the output signal SA indicates that the coil at OUT A is expected to be floating, SB indicates the coil 
at OUT B is expected to be floating, and the output signal SC indicates the coil at OUT C is expected to be 
floating. The signals on lines 101 and 100 likewise, indicate whether the floating coil (that is, whichever may 

10 be instantaneously floating) is expected to experience a back emf zero crossing from the negative or positive 
direction. 

In order to assist the back emf Amplifier 14 and logic circuit 95 to properly detect the zero crossing of the 
selected floating coil, the noise generated in the operation of various circuit elements, especially noise gen- 
erated by the commutation of the driven coils, which tend to ring for some time after switching, and noise gen- 
15 erated in the sequencer circuit is masked. To accomplish this masking function, as well as other circuit func- 
tions enabled by the method of operation of the circuit of the invention, the mask circuit 105 of Figure 7 is 
provided. 

The mask circuit 105 has an up counter 110, and three down counters 111, 112, and 113. The up counter 
110 serves as a period counter to provide a digital count on its output corresponding to the time between actual 

20 zero crossings of the selected floating coils, detected by the zero crossing circuitry described above with ref- 
erence to Figure 5. The up counter 110 receives a clock signal in put from a clock frequency divider 120, which 
divides the system clock frequency to a desired frequency, the particular frequency selected determining the 
resolution of the system. The up counter 110 is reset by the reset pulse produced by the NAIMD gate 102 in 
the circuit of Figure 5, after a zero crossing has been detected. Accordingly, the up counter 110 starts to count 

25 after being reset upon detection of a first actual zero crossing,, and continues the count until being again reset 
upon the detection of the next actual zero crossing. 

The outputs of the up counter 110 are connected to the inputs of each of the down counters 111 , 112, and 
113, which serve various mask and control functions. The down counter 111 determines a mask time during 
which the noise of the sequencer circuit 13, shown in Figure 4, as well as the noise produced by the coils 32, 

30 33, and 34 in response to being commutated, is masked. The down counter 111 (hereafter referred to as the 
mask counter 111) produces an output on the line 120 when the desired mask count has been reached. The 
output signal on the line 120 is used to enable the transmission gate 89 in the zero crossing detector in Figure 
5, so that no zero crossing can be detected until the expiration of the mask period. The mask counter 111 re- 
ceives a "LOAD" signal from line 121, the "LOAD" signal being produced by the output of the NAND gate 103, 

35 shown in Figure 5, just prior to the occurrence of the RESET pulse upon the output of the NAND gate 102. 
When the load signal appears on the load input of the mask counter 111, the count then existing in the period 
counter 110 is immediately loaded into the mask counter 111. 

The mask counter 111 also receives a clock signal from a frequency divider 123. If desired, a number of 
select terminals 124 may be provided enable the divisor of the frequency divider 123 to be controlled to allow 

40 the resolution of the mask count to be selected for a particular application in which the driver circuit 10 will 
be used. 

Thus, in operation, when an actual zero crossing of a selected floating coil is detected by the circuitry of 
Figure 5, the count which exists in the up counter 110 is loaded into the mask counter 111. The up counter 
110 is reset to begin a new period count that will continue until the occurrence of the next zero crossing, at 

45 which time, the new count will be loaded into the mask counter 111 , the up counter 110 reset, and the process 
repeated. It can therefore be seen that the actual mask time determined by the mask counter 111 will vary, 
depending upon the speed of rotation of the motor. (The percentage of the number of rotational degrees, how- 
ever, will remain constant.) 

In a similar fashion, the down counter 112 (hereafter referred to as the delay counter 112) serves to meas- 

50 urea time corresponding to a desired delay after the detection of a zero crossing before the coils are switched 
to the next commutation sequence. The delay counter 112 also receives a divided clock frequency from a fre- 
quency divider 126, the divisor of which may be selected by applying an appropriate signal to one of the select 
lines 127. The operation of the load and count functions are essentially the same as the operation of the mask 
counter 111 above described. However, it is noted that the time calculated by the delay counter 112 indicated 

55 by the output on line 122 may be substantially longer than the time calculated by the mask counter 111 , the 
time being a function of the clock frequency, and/or if desired, by the number of bits of the period counter 110 
which are loaded. The output signal on the line 122 is used to increment the sequencer 13 (see Figure 2), as 
well as to enable the mask counter 111 . By creating the delay between the zero crossing and incrementing to 
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the next phase, the torque ripple can be optimized to take advantage of the inertia of the rotor. 

Thus, the inverted output of the delay counter 112 on the line 122 is applied to the clock input of the mask 
counter 111 by a NAND gate 141 to which the clock pulses from the frequency divider 123 are also applied. 
The signal on the line 122, therefore, inhibits the application of the clock pulses to the mask counter 111 until 
5 after the completion of the delay count by the delay counter 112. The counts of the mask counter 111 and the 
delay counter 112 are therefore sequential, with the mask count of the mask counter 111 following the com- 
pletion of the delay count of the delay counter 112 to mask switching and commutation noise, as described 
above, so that spurious zero crossings caused by switching noise will not be interpreted as an actual zero cross- 
ing of the selected floating coil. 

10 Because the mask circuitry 105 of Figure 7 operates on the actual, not expected, zero crossing signals 

of the floating rotor coils, many motor control functions which have been heretofore not possible to achieve 
are enabled. In addition, other motor control functions can easily be achieved. For example, additional down 
counters, such as the down counter 113 mentioned above can provide useful functions, such as a speed slow- 
down determination. The down counter 113 is referred to hereafter as the slow-down counter 113. The slow- 

15 down counter 113 operates in the same way as the mask counter 111 and delay counter 112, receiving a clock 
signal divided in frequency from the system clock frequency by a frequency divider 128. If desired, select input 
lines 129 may be provided to allow the frequency divisor to be selected for particular motor driver applications. 
By appropriately selecting the clock frequency applied to the slow-down counter 112 so that the down count 
will be longer than the time between actual zero crossings of the commutated floating coils, if the output signal 

20 on line 130 changes states, indicating that the slow-down counter 113 has completed its count, the signal in- 
dicates that the motor is slowing down. That is, the appearance of a signal on the output line 130 indicates 
that the period counted is greater than the previous period which was loaded into the counter, indicating that 
the motor is slowing down. 

For alt of the counters 110, 111, 112, and 113, NAND gates 133, 134, 135, and 136 are provided to com bine 

25 the outputs of the respective counters are combined, to provide an output which is combined with the respec- 
tive clock signals by NAND gates 140, 141, 142, and 143. Thus, the count of any of the counters 112, or 113 
is allowed only to reach its maximum up or down count, and its count is stopped so that the counter will not 
recycle and begin a new count. 

The overall operation of the circuit 10 will now be described, with reference to the waveforms which are 

30 developed in the various parts of the circuit, as shown in Figure 8. The rotational degree index curves 160 for 
each coil are shown across the top of the waveforms for reference. Each sinusoidal waveform is labeled to 
correspond to the node to which each of the coils is connected: coil 32 - A, coil 33 - B, and coil 34 - C. Beneath 
the rotational degree curves 160 is the corresponding commutation sequence which occurs at the specified 
rotational position. 

35 The next three curves 164, 165, and 1 66 show the voltages of the respective driven coils A, B, and C. It 
can be seen that for one electrical cycle, indicated at the bottom of the curves of Figure 6, each coil will have 
two sequences in which it has positive voltage, two sequences in which it has negative voltage, and two se- 
quences during which it floats. For example, referring to the curves representing the voltage on coil A, the 
first two voltages 170 and 171 of sequences 1 and 2 during which current flows respectively from coil A to 

40 coil B, and from coil Ato coil C, are positive. During the time coil Afloats in sequence 3 the voltage 173 changes 
from positive to negative. The next two voltages 1 74 and 1 75 of sequences 4 and 5 during which current flows 
respectively from coil B to coil A, and from coil C to coil A, are negative. Finally, when coil Aagain floats during 
sequence 6, the voltage 176 changes from negative to positive. The other coils B and C have similar voltage 
curves, each displaced 120° from each other. 

45 it can be seen that each coil floats twice during one electrical cycle, and has two zero crossings; however, 

one zero crossing has a negative slope, from positive to negative, and the other has a positive slope, from 
negative to positive. Thus, an ambiguity would exist if the rotor position were to be determined solely on the 
basis of a zero crossing without regard to the direction of the crossing. (This was one of the shortcomings of 
previous motor driver systems.) Thus, when the voltage, for example of coil A, transitions from positive to neg- 

50 ative, shown by curve 173, a zero crossing 180 is detected by the zero crossing circuit 80, shown in Figure 5. 
Moreover, the direction of the crossing also is detected by the slope detecting circuitry 95, also shown in Figure 
5. Once the zero crossing has been detected, and after the delay count of the delay counter 112 has been 
reached, the sequence is incremented, oommutating the coils, and starting the mask period counter 111 . When 
the mask period has expired, the zero crossing detector is then allowed to look for the zero crossing of the 

55 next floating coil; in this case of coil C, which will be transitioning from negative to positive, as can be seen 
from the curve 182 in Figure 8. After its zero crossing is detected and commutation performed, the positive 
to negative zero crossing of floating coil B, shown by the curve 183 is sought, and so forth. Finally, the mask 
signal 190 which would be produced on the line 120 of the mask circuit of Figure 7 is shown in the bottom 
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curves of Figure 8. The mask curve has two portions, for example 191 and 192, corresponding to the mask 
times of the delay counter 112 and the mask counter 111, respectively. 

In summary, the commutation sequence is as follows: the sequencer circuit establishes a desired rotor 
phase, and the zero crossing detector detects its actual occurrence by finding the proper zero crossing. When 

5 the zero crossing is detected, first a delay is generated by the delay counter 112, after which the rotor coils 
are commutated, and a mask is generated by the mask counter 111. The identity of the next floating coil is 
determined by the phase information being generated from the output signals of the shift register 55, and the 
identified coil is connected to the back emf amplifier 85 by closing the proper switch 81, 82, or 83. 

It can be seen that throughout the process, two key elements exist: 1) the anticipated zero crossing is 

10 first established and 2) only the actual zero crossing is detected which corresponds to that previously estab- 
lished. Until the actual zero crossing which is anticipated is detected, no commutation occurs. Thus, the se- 
quencer 1 3 is always synchronized to the actual motor position, even if the drive signals to the motor are re- 
moved. For example, if the driver circuit 10 includes an overtemperature warning signal, a circuit can be pro- 
vided to block the drive signals to the motor until the overtemperature condition is corrected. When the drive 

15 signals are blocked, of course the motor wi II slow down, but the sequencer will nevertheless remain synchron- 
ized to the motor rotation, so that when the overtemperature condition is corrected, drive can be immediately 
reapplied to bring the motor back up to operating speed without elaborate resynchronizing techniques. The 
same is true of other events which would otherwise cause the motor to lose synchronization with the sequenc- 
er, such as a bump to a disk driven by the motor, or the like. 

20 Although the invention has been described and illustrated with a certain degree of particularity, it is un- 
derstood that the present disclosure has been made by way of example only, and that numerous changes in 
the combination and arrangements of parts and features can be made by those skilled in the art without de- 
parting from the spirit and scope of the invention, as hereinafter claimed. 

25 

Claims 

1 . A circuit for operating a polyphase dc motor having a plurality of driving coils, comprising: 

a circuit to provide instantaneous drive currents to selected ones of said driving coils in a each of 
30 a plurality of predetermined commutation sequences; 

circuitry for detecting zero crossings of a back emf voltage of the coils connected into a f loating 
state during each of said predetermined commutation sequences to produce a back emf detection signal 
for timing changes among said predetermined commutation sequences; 

circuitry for controlling the drive currents to said selected driving coils to be turned on and off; 
35 and circuitry for delaying zero crossing detection for a predetermined time after the drive currents 

are turned-off. 

The circuit of claim 1 wherein said circuitry for controlling the drive currents to said selected driving coils 
to be turned on and off comprises circuitry for generating a chop signal when the current in said active 
coils exceeds a predetermined threshold. 

3. The circuit of clai m 2 wherein said circuitry for controlling the drive currents to said selected driving coils 
to be turned on and off comprises PWM circuitry. 

4. The circuit of claim 2 wherein said circuitry for delaying zero crossing detection comprises circuitry for 
controlling a back emf sampling time to allow sampling at time of minimum back emf induced noise. 

The circuit of claim 4 wherein said circuitry for delaying zero crossing detection comprises circuitry for 
controlling a back emf sampling time to allow sampling only between times when the drive current cir- 
cuitry controls the drive current to be turned on and when the circuit to provide instantaneous drive cur- 
rents to selected ones of said driving coils actually applies current. 

6. The circuit of claim 4 wherein said circuitry for delaying zero crossing detection further comprises a flip- 
flop that is clocked by the circuitry for controlling the drive currents to said selected driving coils to be 
turned on and off. 

7. A circuit for operating a sensorless polyphase dc motor having a plurality of driving coils, comprising: 
a commutation sequencer for producing signals in each of a plurality of commutation sequences 

to identify which of said driving coils are to be active to receive instantaneous drive currents and which 
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are to be connected into a floating state; ' 

drive circuitry for connecting said coils to receive the instantaneous drive currents and into the 
floating state in accordance with the signals from said commutation sequencer; 

circuitry for detecting zero crossings of a back emf voltage of the coils connected into the floating 
5 states to produce a back emf detection signal; 

circuitry responsive to the back emf detection signal for producing a delayed signal to increment 
the commutation sequencer to a next commutation sequence; 

circuitry for generating a chop signal when the current in said active coils exceeds a predetermined 
threshold; 

10 circuitry for turning the drive currents supplied to the selected active coils on and off to modulate 

the drive currents in accordance with said chop signal; 

circuitry for delaying a detection of a next zero crossing for a predetermined time after the drive 
currents are turned-off by said chop signal. 

15 8. The circuit of claim 7 wherein said drive circuitry is a triple - Vz - H - bridge, and comprises FET power 
transistors. 

9. The circuit of claim 7 wherein said circuitry for detecting zero crossings of a back emf voltage comprises 
a comparator switchably connected to each coil when it is connected in a floating state operable to produce 

20 an output when the voltage on the floating coil crosses a reference voltage. 

10. The circuit of claim 7 wherein said circuitry for turning the drive currents supplied to the selected active 
coils on and off comprises circuitry for generating a chop signal when the current in said active coils ex- 
ceeds a predetermined threshold. 



25 



45 



50 



11. The circuit of claim 10 wherein said circuitry for turning the drive currents supplied to the selected active 
coils on and off comprises PWM circuitry. 



12. The circuit of claim 7 wherein said circuitry for delaying a detection of a next zero crossing comprises 
circuitry for controlling a back emf sampling time to allow sampling at time when minimum back emf in- 

30 duced noise exists on the floating coil. 

13. The circuit of claim 12 wherein said circuitry for delaying a detection of a next zero crossing comprises 
circuitry for controlling a back emf sampling time to allow sampling only between times when the circuitry 
for turning the drive currents supplied to the selected active coils on and off controls the drive current 

35 to be turned on and when the drive circuitry actually connects said coils to receive the instantaneous 

drive currents. 

14. The circuit of claim 13 wherein said circuitry for delaying a detection of a next zero crossing further com- 
prises a flip-flop that is clocked by the circuitry for controlling the drive currents to said selected driving 

40 coils to be turned on and off. 

15. The circuit of claim 6 or claim 14 wherein said flip-flop is connected to receive an output of said circuitry 
for detecting zero crossings. 



16. The circuit of claim 1 or claim 7 wherein the polyphase dc motor is a sensorless, brushless polyphase 
dc motor. 

1 7. A method for operating a polyphase dc motor having a plurality of driving coils, comprising: 
chopping drive current supplied to said driving coils to control the maximum current delivered 

thereto by turning the drive current on and off; 

detecting zero crossings of a back emf voltage of said driving coils that are connected into a floating 
state for producing a commutation signal; and 

inhibiting the detection of zero crossings for a predetermined time after the drive current is turned 
off during said chopping step to avoid detecting a false zero crossing. 

55 18. The method of daim 17 wherein said chopping is performed as a part of a PWM operation. 

19. The circuit of claim 18 wherein said inhibiting is performed for a time sufficient to allow PWM induced 
noise to be minimum. 
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20. The circuit of claim 18 wherein said inhibiting is performed to allow sampling only between times when 
the drive current circuitry controls the drive current to be turned on and when the circuit to provide in- 
stantaneous drive currents to selected ones of said driving coils actually applies current 
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